<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>仓库管理系统</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
    <link rel="stylesheet" href="/resources/css/public.css" media="all" />
    <link rel="stylesheet" href="/resources/layui_ext/dtree/dtree.css" media="all" />
    <link rel="stylesheet" href="/resources/layui_ext/dtree/font/dtreefont.css" media="all" />
</head>
<body class="childrenBody">
<!--搜索条件开始-->
<div>
    <fieldset class="layui-elem-field layui-field-title" style="margin-top: 20px;">
        <legend>查询条件</legend>
    </fieldset>
    <form class="layui-form layui-form-pane" lay-filter="searchFrm" id="searchFrm" name="searchFrm" method="post">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">权限名称</label>
                <div class="layui-input-inline">
                    <input type="text" name="title" id="title" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">权限编码</label>
                <div class="layui-input-inline">
                    <input type="text" name="percode"  autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>

        <div class="layui-form-item" style="text-align: center">
            <div class="layui-inline">
                <button type="button" class="layui-btn layui-btn-normal  layui-icon layui-icon-search" lay-filter="doSearch" lay-submit="">查询</button>
                <button type="reset" class="layui-btn layui-icon layui-icon-refresh">重置</button>
            </div>
        </div>
    </form>
</div>
<!--搜索条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="PermissionTable" lay-filter="PermissionTable"></table>
        <div id="PermissionToolBar" style="display: none;">
            <button type="button" lay-event="addPermission" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-add-circle"></span>添加权限</button>
        </div>
    <div id="permissionRowBar" style="display: none">
        <button type="button" lay-event="delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
        <button type="button" lay-event="update" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-set-sm"></span>更新</button>
    </div>
</div>
<!--数据表格结束-->

<!-- 添加和修改的弹出层开始 -->
<div style="display: none;padding: 5px" id="addOrUpdateDiv">
    <form action="" method="post" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm">
        <div class="layui-form-item">
            <label class="layui-form-label">选择菜单</label>
            <div class="layui-input-block">
                <input type="hidden" name="pid" id="pid" lay-verify="required">
                <ul id="permissionTree" class="dtree" data-id="0"></ul>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">权限名称</label>
            <div class="layui-input-block">
                <input type="hidden" name="id">
                <input type="text" name="title" lay-verify="required" autocomplete="off" placeholder="请输入权限名称" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">权限编码</label>
            <div class="layui-input-block">
                <input type="text" name="percode" autocomplete="off" placeholder="例如 menu:update" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">是否展开</label>
                <div class="layui-input-inline">
                    <input type="radio" name="open" value="1" title="展开" >
                    <input type="radio" name="open" value="0" title="不展开" checked="" >
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">是否可用</label>
                <div class="layui-input-inline">
                    <input type="radio" name="available" value="1" title="可用" checked="">
                    <input type="radio" name="available" value="0" title="不可用" >
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">排序码</label>
            <div class="layui-input-inline">
                <input type="text" name="ordernum" id="ordernum" lay-verify="required|number"  autocomplete="off" placeholder="请输入排序码[>0]" class="layui-input">
            </div>
        </div>

        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;">
                <button type="button" class="layui-btn" lay-submit="" lay-filter="doSubmit" id="doSubmit" ><span class="layui-icon layui-icon-add-1"></span>提交</button>
                <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
            </div>
        </div>
    </form>
</div>
<!-- 添加和修改的弹出层结束 -->

<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script>
    var tableIndex;

    layui.extend({
        dtree: '/resources/layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
    }).use(['jquery','layer','form','table','dtree'],function () {
            var form = layui.form;
            var $ = layui.jquery;
            var layer = layui.layer;
            var table = layui.table;
             var dtree=layui.dtree;

            tableIndex = table.render({
                elem: '#PermissionTable'
                ,url:'/permission/loadAllPermission'
                ,toolbar: '#PermissionToolBar' //开启头部工具栏，并为其绑定左侧模板
                ,title: '权限表'
                ,height: 'full-220'
                ,page: true
                ,cols: [ [
                    {field:'id', title:'ID',align:'center'}
                    ,{field:'pid', title:'菜单ID',align:'center'}
                    ,{field:'title', title:'权限名称',align:'center'}
                    ,{field:'percode', title:'权限编码',align:'center'}
                    ,{field:'available', title:'是否可用',align:'center',templet:function(d){
                        return d.available==1?'<font color=blue>可用</font>':'<font color=red>不可用</font>';
                    }}
                    ,{field:'ordernum', title:'排序码',align:'center'}
                    ,{fixed: 'right', title:'操作', toolbar: '#permissionRowBar',align:'center',width:'200'}
                ] ]
                ,done:function(data,curr,count){
                    //curr当前页  count数据总条数
                    //不是第一页如果返回的数据为0那么就返回上一页
                    if(data.data.length==0&&curr!=1){
                        tableIndex.reload({
                            page:{
                                curr:curr-1
                            }
                        });
                    }
                }
            });

            //模糊查询
            form.on('submit(doSearch)',function(data){
                var params = $("#searchFrm").serialize();
                tableIndex.reload({
                    url: "/permission/loadAllPermission?" + params,
                    page:{
                        curr:1
                    }
                })
                return false;
            });

            //头工具栏事件
            table.on('toolbar(PermissionTable)', function(obj){
                switch(obj.event){
                    case 'addPermission':
                        openAddPermission();
                        break;

                };
            });

        //监听行工具条的事件
        table.on("tool(PermissionTable)",function(obj){
            var data = obj.data; //获得当前行数据
            switch(obj.event){
                case 'delete':
                    DeletePermission(data);
                    break;
                case 'update':
                    UpdatePermission(data);
                    break;
                
            };
        });

            var url;
            var mainIndex;

            //添加添加页面
            function openAddPermission() {
                mainIndex = layer.open({
                    type:1,
                    title:'添加部门',
                    content:$("#addOrUpdateDiv"),
                    area:['800px','550px'],
                    success:function(index){
                        //清空表单数据
                        $("#pid").val("");
                        $("#dataFrm")[0].reset();
                        url = "/permission/addPermission";
                        $.get("/permission/loadPermissionMaxOrderNum",function (data) {
                             $("#ordernum").val(data.value);
                        })

                        //关闭  因为上次没有关闭的下拉层页面
                        $("div[dtree-id][dtree-select]").removeClass("layui-form-selected");
                        $("div[dtree-id][dtree-card]").removeClass("dtree-select-show layui-anim layui-anim-upbit");
                    }
                });
            }

            //更新页面
            function UpdatePermission(data){
                mainIndex = layer.open({
                    type:1,
                    title:'添加公告',
                    content:$("#addOrUpdateDiv"),
                    area:['800px','550px'],
                    success:function(index){
                        form.val("dataFrm",data);
                        //下拉树赋值
                        dtree.dataInit("permissionTree", data.pid);
                        var selectParam = dtree.selectVal("permissionTree"); //selectParam是必须的

                        //console.log(selectParam);
                        url="/permission/updatePermission";

                        //关闭  因为上次没有关闭的下拉层页面
                        $("div[dtree-id][dtree-select]").removeClass("layui-form-selected");
                        $("div[dtree-id][dtree-card]").removeClass("dtree-select-show layui-anim layui-anim-upbit");

                    }
                });
            }

        //保存
        form.on("submit(doSubmit)",function(obj){
            //序列化表单数据
            var params=$("#dataFrm").serialize();
            $.post(url,params,function(obj){
                layer.msg(obj.msg);
                //关闭弹出层
                layer.close(mainIndex);
                //刷新数据 表格
                if (obj.code ==200){
                    //数据表格刷新
                    tableIndex.reload();
                }
            })
            return false;
        });

        //删除
        function  DeletePermission(data) {
            //console.log(data);

            layer.confirm('你确定要删除这条数据吗?', {icon: 3, title:'提示'}, function(index){
                $.post("/permission/deletePermission",{id:data.id},function(res){
                    if(res.code==200){
                        //数据表格刷新
                        tableIndex.reload();
                    }
                    layer.msg(res.msg);
                })
                layer.close(index);
            });

        }

                //初始化下拉树
                var selectTree=dtree.renderSelect({
                    elem: "#permissionTree",
                    width: "100%", // 可以在这里指定树的宽度来填满div
                    url: "/menu/loadMenuManagerLeftTreeJson" ,// 使用url加载（可与data加载同时存在）
                    method:'get',//这里要改为get才能用
                    dataStyle:"layuiStyle",
                    response:{message:"msg",statusCode:0}, //默认0成功
                    dataFormat:"list"
                });
                //监听下拉树点击的方法 给标签中id="pid' 的进行赋值 下拉树中的属性值很难获取
                dtree.on("node(permissionTree)" ,function(obj){
                    $("#pid").val(obj.param.nodeId);
                });


        })

    function reloadTable(id) {
        tableIndex.reload({
            url: "/permission/loadAllPermission?id=" + id
        })
    }
</script>
</body>
</html>